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TITLE OF THE INVENTION 

METHOD AND SYSTEM FOR DATA COMMUNICATION BETWEEN DEVICES 

5 FIELD OF THE INVENTION 

This invention relates to a method and system for 
data communication between devices and, more 
particularly, to a data communication method in an image 
10 processing system comprising an image input/output unit 
and an image control unit. 

BACKGROUND OF THE INVENTION 

15 In a system of the kind in which an image 

input /output unit and an image control unit, for 
example, are controlled by independent CPUs, the 
conventional practice when sending and receiving 
variable- length messages between the units is for the 
20 CPUs to control communication controllers on per-byte 
(eight -bit) basis. 

In this example of the prior art, a CPU interrupt 
is generated byte by byte. When data communication 
takes place at high speed, therefore, some data may 
2 5 failed to be acquired and other processing by the CPU 
may be adversely affected. Depending upon the 
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communication controller, it is possible to use a FIFO 
buffer to reduce the frequency with which CPU interrupt 
occurs, though often the communication controller that 
is incorporated within a low-cost single-chip 
microcontroller does not come equipped with this 
function. A microcontroller that is available can 
perform data transfer without the intervention of a CPU 
by using a combination of a DMA controller and a 
communication controller. However, since the length of 
received messages is indeterminate, the DMA transfer 
length cannot be set in advance. This necessitates an 
operation in which a CPU polls the counter of the DMA 
controller. Such a microcontroller, therefore, is not 
suitable for receiving variable- length messages as is. 

Meanwhile, there is a tendency for the amount of 
data transferred between devices to increase as 
functions become more sophisticated. For example, when 
the image processing speed of an image input/output unit 
rises, communication time allowed for control between 
pages tends to shorten. Hence there is a demand for 
ever higher data communication speed. 

SUMMARY OF THE INVENTION 

Accordingly, an object of the present invention is 
to provide a method and system for data communication 



between devices, wherein by adopting a scheme in which a 
variable- length message is transferred upon being 
divided into fixed-length packets, it is possible to 
combine and control a DMA controller and a communication 
controller, thereby achieving high-speed data 
communication, even in a low-cost single-chip 
microcomputer . 

According to the present invention, the foregoing 
object is attained by providing an image processing 
system comprising a combination of an image control unit 
and one or a plurality of image input/output units, 
wherein the image input /output unit and the image 
control unit are connected by communication means, the 
image control unit has first communication control means 
connected to the communication means, the image 
input/output unit has second communication control means 
connected to the communication means, and the system 
further includes control means for performing control so 
as to set predetermined communication conditions in the 
first and second communication control means at 
initialization, decide fixed packet length based upon 
mutually communicable packet lengths of packets 
exchanged via the communication means, set the decided 
fixed packet length in the first and second 
communication control means anew, and continue 
subsequent communication by DMA transfer in which a data 



string is divided into the set fixed packet lengths. 

In a case where the data string is a variable- 
length message, the control means performs control in 
such a manner that a transmitting side adds information 
5 indicative of the end of a message onto a final packet 
when the variable- length message is transmitted upon 
being divided into fixed- length packets, and a receiving 
side reproduces the original variable- length message 
after recognizing added-on final-packet information. 
10 Further, the control means includes first control means 
in the image control unit for controlling the first 
communication control means, and second control means in 
the image input/output unit for controlling the second 
communication control means. Further, the decision of 
15 the fixed packet length is made by the first control 

means. Further, the decision of the fixed packet length 
is made by the second control means. Further, the fixed 
packet length decided upon is whichever of the packet 
lengths of respective ones of the first and second 
20 communication control means is smaller than an upper- 
limit value. Further, an image reading unit is 
connected as the image input/output unit and the system 
operates as an image reading system. Further, an image 
forming unit is connected as the image input/output unit 
2 5 and the system functions as an image forming system. 

Further, an image reading unit and an image forming unit 



are connected as the image input/output units and the 
system functions as an image input /output system. 
Further, start-stop synchronization serial communication 
means is used as the communication means, a serial 
5 communication controller and a DMA controller are 

combined as the communication control means, the DMA 
controller transfers data by the fixed-length packets in 
accordance with a data transfer request from the serial 
communication controller and interrupts the image 
10 control unit when transfer of the fixed-length packet is 
completed. 

Further, the present invention provides a system 
constructed by combining a plurality of devices and 
connecting them by communication means, wherein a first 

15 device has first communication control means connected 
to the communication means, a second device has second 
communication control means connected to the 
communication means, and the system further includes 
control means for performing control so as to set 

2 0 predetermined communication conditions in the first and 
second communication control means at initialization, 
decide fixed packet length based upon mutually 
communicable packet lengths of packets exchanged via the 
communication means, set the decided fixed packet length 

25 in the first and second communication control means 
anew, and continue subsequent communication. 



In a case where a data string is a variable- length 
message, the control means performs control in such a 
manner that a transmitting side adds information 
indicative of the end of a message onto a final packet 
5 when the variable- length message is transmitted upon 

being divided into fixed-length packets, and a receiving 
side reproduces the original variable- length message 
after recognizing added-on final-packet information. 
Further, the present invention provides a data 

10 communication method in an image processing system 

comprising a combination of an image control unit and 
one or a plurality of image input /output units, the 
image input /output unit and the image control unit being 
connected by communication means, wherein in a case 

15 where the image control unit has first communication 

control means connected to the communication means and 
the image input/ output unit has second communication 
control means connected to the communication means, the 
method comprises an initial communication conditions 

20 setting step of setting predetermined communication 

conditions in the first and second communication control 
means at initialization; a fixed packet length deciding 
step of deciding fixed packet length based upon mutually 
communicable packet lengths of packets exchanged via the 

25 communication means; and a fixed packet length setting 
step of setting the decided fixed packet length in the 



first and second communication control means anew and 
continuing subsequent communication by DMA transfer in 
which a data string is divided into the set fixed packet 
lengths . 

In the fixed-packet length deciding step, the fixed 
packet length decided upon is whichever of the packet 
lengths of respective ones of the first and second 
communication control means is smaller than an upper- 
limit value. Further, after the fixed packet length has 
been set anew, communication is resumed upon elapse of a 
predetermined period of time. Further, start-stop 
synchronization serial communication means is used as 
the communication means, a serial communication 
controller and a DMA controller are combined as the 
communication control means, the DMA controller 
transfers data in the fixed- length packet in accordance 
with a data transfer request from the serial 
communication controller and interrupts the image 
control unit when transfer of the fixed-length packet is 
completed. 

Further, the present invention provides a data 
communication method in a system constructed by 
combining a plurality of devices and connecting them by 
communication means, wherein in a case a first device 
has first communication control means connected to the 
communication means and a second device has second 



communication control means connected to the 
communication means, the method comprises the steps of: 
setting predetermined communication conditions in the 
first and second communication control means at 
5 initialization; deciding fixed packet length based upon 
mutually communicable packet lengths of packets 
exchanged via the communication means; and setting the 
decided fixed packet length in the first and second 
communication control means anew and continuing 

10 subsequent communication. 

In a case where a data string is a variable- length 
message, a transmitting side adds information indicative 
of the end of a message onto a final packet when the 
variable- length message is transmitted upon being 

15 divided into fixed-length packets, and a receiving side 
reproduces the original variable- length message after 
recognizing added-on final-packet information. 

Further, the present invention provides a storage 
medium storing a computer -readable communication control 

20 program of an image processing system comprising a 
combination of an image control unit and one or a 
plurality of image input/output units, the image 
input /output unit and the image control unit being 
connected by communication means, wherein in a case 

2 5 where the image control unit has first communication 

control means connected to the communication means and 



the image input/output unit has second communication 
control means connected to the communication means, the 
communication control program includes an initial 
communication conditions setting step of setting 
5 predetermined communication conditions in the first and 
second communication control means at initialization; a 
fixed packet length deciding step of deciding fixed 
packet length based upon mutually communicable packet 
lengths of packets exchanged via the communication 

10 means; and a fixed packet length setting step of setting 
the decided fixed packet length in the first and second 
communication control means anew and continuing 
subsequent communication by DMA transfer in which a data 
string is divided into the set fixed packet lengths. 

15 The communication control program includes a 

program in the image control unit executed by a first 
control unit for controlling the first communication 
control means, and a program in the image input/output 
unit executed by a second control unit for controlling 

20 the second communication control means. 

Other features and advantages of the present 
invention will be apparent from the following 
description taken in conjunction with the accompanying 
drawings, in which like reference characters designate 

2 5 the same or similar parts throughout the figures 
thereof . 



BRIEF DESCRIPTION OF THE DRAWINGS 

Fig. 1 is a block diagram illustrating an example 
5 of the control components of an image input/output 
system according to an embodiment of the present 
invention; 

Fig. 2 is a sectional view showing an example of 
the configuration of the image input/output system 
10 according to this embodiment ; 

Fig. 3 is a block diagram showing an example of the 
construction of a controller according to this 
embodiment ; 

Fig. 4 is a block diagram showing an example of the 
15 construction of a reader according to this embodiment; 

Fig. 5 is a block diagram illustrating a detailed 
arrangement relating to communication control in the 
reader according to this embodiment; 

Figs. 6A and 6B are flowcharts illustrating an 
20 example of processing for deciding communication 
conditions according to this embodiment; 

Figs. 7A and 7B are flowcharts illustrating an 
example of processing for sending and receiving messages 
according to this embodiment; and 
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Fig. 8 is a diagram showing an example of the 
format of a transfer message and packets according to 
this embodiment. 



5 DESCRIPTION OF THE PREFERRED EMBODIMENTS 

<Example of system configuration according to 
this embodiment > 

An example of the overall configuration of an image 

10 input/output system serving as an image processing 
system according to an embodiment of the present 
invention will be described with reference to Fig. 1. 
Though the description of this embodiment is rendered 
based upon an image input/output system, the technical 

15 concept of the present invention is applicable to 
systems relating to the setting of communication 
conditions in a case where a plurality of devices having 
different capabilities are connected to a single device, 
and the present invention covers these systems. 

20 As shown in Fig. 1, a reader (image input unit) 2 00 

reads a document image optically and converts the image 
to image data. The reader 200 is constituted primarily 
by a scanner unit 210 having a function for reading a 
document, and a document feeder unit 250 having a 

25 function for transporting the paper sheets of the 
document . 
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A printer (image output unit) 3 00 transports 
printing paper, prints image data on the printing paper 
in the form of a visible image and discharges the paper 
to the exterior of the apparatus. The printer 3 00 is 
5 constituted primarily by a paper feed unit 310 having 
printing paper cassettes of a plurality of types, a 
marking unit 320 having a function for transferring 
image data to printing paper and fixing the image on the 
paper, and a paper discharge unit 330 having a function 
10 for sorting printing paper that has been printed on, 

stapling the paper and outputting the stapled paper to 
the exterior of the apparatus . 

A controller (image control unit) 110 is 
electrically connected to the reader 200 and printer 300 
15 and is further connected to host computers 401 and 402 
via a network 400. 

The controller 110 controls the reader 2 00 to read 
in image data representing a document and controls the 
printer 3 00 to output image data to printing paper, 
20 thereby providing a copy function. The controller 110 
further provides a scanner function for converting read 
image data from the reader 200 to code data and 
transmitting the code data to the host computers via the 
network 400, and a printer function for converting code 
25 data received from a host computer via the network 400 
to image data and outputting the image data to the 
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printer 300. 

A console 150, which is connected to the controller 
110, is constituted by a liquid-crystal touch-sensitive 
panel to provide a user interface for operating the 
5 image input /output system. 

Fig. 2 is a sectional view showing the construction 
of the reader 200 and printer 300. 

(Example of construction of reader) 
The document feeder unit 250 of the reader feeds 
10 documents to the top of a platen glass one sheet at a 
time in order starting from the first sheet and then 
discharges the documents from the platen glass 211 when 
the reading of the documents is completed. When a 
document is transported to the top of the platen glass 
15 211, a lamp 212 is lit and an optics unit 213 is caused 
to start moving so that the document is exposed and 
scanned. Light reflected from the document at this time 
is introduced to a CCD image sensor (referred to as a 
"CCD" below) 218 by mirrors 214, 215, 216 and a lens 
2 0 217. Thus, the image of the scanned document is read by 
the CCD 218. Image data output from the CCD 218 is 
subjected to predetermined processing and then 
transferred to the controller 110. 

(Example of construction of printer) 
25 A laser driver 321 in the printer 300 drives a 

laser emission unit 322. Specifically, the laser driver 



321 causes the laser emission unit 322 to emit laser 
light that conforms to the image data that has been 
output from the controller 110. The laser light 
irradiates a photosensitive drum 323 so that a latent 
5 image conforming to the laser light is formed on the 
drum 323. A developing unit 324 causes a developing 
agent to attach itself to the latent image formed on the 
photosensitive drum 323. 

Printing paper is transported to a transfer unit 

10 325 from a cassette 311 or 312 at a timing synchronized 
to the start of irradiation by the laser light, as a 
result of which the developing agent affixed to the 
photosensitive drum 323 is transferred to the printing 
paper. The printing paper to which the developing agent 

15 has been transferred is transported to a fixing unit 

326, where the developing agent is fixed on the printing 
paper by heat and pressure supplied by the fixing unit 
326. Upon passing through the fixing unit 326, the 
printing paper is ejected by ejection rollers 327. A 

20 paper discharge unit 33 0 gathers the discharged sheets 
of paper together, sorts the sheets and staples sheets 
that have been sorted. 

If the apparatus has been set to a double-sided 
printing mode, the printing paper is transported up to 

25 the position of the ejection rollers 327, the rotating 
direction of the ejection rollers 2 08 is reversed and 
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the paper is introduced to a paper re-feed path 329 by a 
flapper 32 8. Printing paper thus rintroduced to the 
paper re-feed path 329 is fed to the transfer unit 325 
at the above-mentioned timing. 
5 (Example of construction of controller) 

An example of the functions of the controller 110 
will be described with reference to the block diagram of 
Fig. 3. 

A main controller 111 is constituted primarily by a 

10 CPU 112, a bus controller 113 and various interface 
control circuits (not shown) . 

The CPU 112 and the bus controller 113 control the 
overall operation of the controller 110. The CPU 112 
operates on the basis of a program read in from a ROM 

15 114 via a ROM interface 115. An operation for analyzing 
PDL (Page Description Language) code data received from 
a host computer and expanding the code data into raster 
image data also is described in this program and is 
implemented by software. A bus controller 113 controls 

2 0 the transfer of data input to and output from various 
interfaces, performs arbitration at the time of bus 
contention and controls DMA data transfer. 

A DRAM 116, which is connected to the main 
controller 111 by a DRAM interface 117, is used as a 

2 5 work area for operation of the CPU 112 and as a work 
area for storing image data. As will be described 
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later, an arrangement may be adopted in which a program 
is loaded in the DRAM 116 from a host computer or 
external storage device (which has been connected to, 
e.g., an expansion connector 124) such as a floppy disk 
5 or CD, and the program is run by the CPU 112. 

A codec 118 compresses raster- image data, which has 
been stored in the DRAM 116, by a compression scheme 
such as MH , MR , MMR or JBIG , etc . , and expands code 
data, which has been compressed and stored, to raster- 

10 image data. An SRAM 119 is used as a temporary work 
area of the codec 118. The codec 118 is connected to 
the main controller 111 via an interface 120, and the 
transfer of data between the codec and the DRAM 116 is 
controlled by a bus controller 113, whereby DMA transfer 

15 is achieved. 

A network controller 121 is connected to the main 
controller 111 by an interface 123 and is connected to 
an external network by a connector 122. Ethernet is an 
example of the external network. 

20 The expansion connector 124 for connecting an 

expansion port and an input /output controller 12 6 are 
connected to a general -purpose high-speed bus 125. A 
PCI bus is an example of the general-purpose high-speed 
bus . 

25 The input /output controller 12 6 is equipped with a 

start- stop synchronization serial communication 
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controller 127 in two channels for sending and receiving 
control commands to and from the CPUs of the reader 200 
and printer 300. The start-stop synchronization serial 
communication controller 127 is connected to external 
5 interface circuits 140, 145 by an input/output bus 128. 
A panel interface 132 comprises an interface 
connected to an LCD controller 131 for presenting a 
display on the liquid-crystal screen of the console 150, 
and a key- input interface 130 for allowing input from 

10 hard keys and keys on a touch- sensitive panel. 

The console 150 has a liquid- crystal display unit, 
a touch-sensitive panel affixed to the liquid-crystal 
display unit, and a plurality of hard keys. Signals 
that have been entered from the touch-sensitive panel or 

15 hardware keys are sent to the CPU 112 via the panel 

interface 132. The liquid-crystal display unit displays 
image data that has been sent from the panel interface 
132 . Functional displays for operating this image 
forming apparatus and displays of image data and the 

20 like are presented on the liquid-crystal display unit. 

A real-time clock module 133 updates/saves date and 
time managed within the apparatus and is backed up by a 
back-up battery 134 . 

Connectors 142 and 147 comprise start- stop 

25 synchronization serial interfaces (143, 148) and video 
interfaces (144, 149) connected to the reader 200 and 
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printer 3 00, respectively. 

A scanner interface 140 is connected to the reader 
200 via the connector 142 and to the main controller 111 
by a scanner bus 141. Depending upon the content of 
5 processing in subsequent processes, the scanner 

interface 140 subjects an image received from the reader 
200 to optimum binarization or to scaling processing for 
main and sub-scans. The scanner interface 140 further 
functions to output, to the scanner bus 141, a control 
10 signal that has been generated based upon a video 
control signal sent from the reader 2 00. 

Transfer of data from the scanner bus 141 to the 
DRAM 116 is controlled by the bus controller 113 . 

A printer interface 145 is connected to the printer 
15 300 via the connector 147 and to the main controller 111 
by a printer bus 146. The printer interface 145 
functions to apply smoothing processing to image data 
output from the main controller 111 and to output the 
processed data to the printer 3 00, and functions also to 
20 output, to the printer bus printer bus 146, a control 
signal that has been generated based upon a video 
control signal sent from the printer 300. 

Transfer of raster- image data, which has been 
expanded in the DRAM 116, to the printer is controlled 
25 by the bus controller 113, and DMA transfer to the 

printer 300 is performed via the printer bus 146 and 



video interface 149. 

(Detailed description of reader) 
A more detailed example of the functional 
construction of the reader will now be described with 
5 reference to the block diagram of Fig. 4. 

A connector 231 is connected to the connector 142 
of the controller 110 and is constituted by the start- 
stop synchronization serial interface 233 for 
communication of commands between the CPU 112 and an MPU 
10 22 8, and the video interface 234 for transferring video 
signals . 

The MPU 228, which is a single-chip CPU for 
performing overall control of the scanner reader, 
internally incorporates the functions of a timer, a 

15 DMAC, a serial communication controller (SCU) and an 
general -purpose input/output port, etc. 

A connector 225 is connected to the document feeder 
unit (referred to as a "DF unit" below) 250. In order 
that a reading operation may be performed, the MPU 228 

20 requests the DF unit 2 50 to feed the paper sheets of a 
document. In response to the request, the DF unit 250 
controls an accompanying motor to implement the 
document- feed operation. 

A CCD driver is incorporated within or connected to 

25 a CCD 218 and is controlled by the MPU 228 via an I/O 

unit 230. Image data that has been input to the CCD 218 
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is photoelectrical].;/ converted to an electric signal. 
The electric signal output from the CCD 218 is amplified 
by an amplifier 221 and then input to an A/D converter 
222. The A/D converter 222 converts the entered analog 
5 electric signal to a digital signal and outputs the 
digital signal. The output signal from the A/D 
converter 222 enters a shading circuit 223, where non- 
uniformity in distribution of light and sensitivity 
unevenness of the CCD are corrected. 

10 The output of the shading circuit 223 is input to a 

timing generator 224 and is transferred to the 
controller 110 via the connector 231 in sync with video 
control signals (HYSNC/VSYNC) generated by the timing 
generator 224. 

15 A ROM 227 is a medium for storing the control 

program of the scanner unit 210. Processing by the MPU 
22 8 is executed based upon this program. A RAM 226 is 
used as a work area when the MPU 22 8 executes 
processing. An arrangement may be adopted in which the 

20 program run by the MPU 22 8 is loaded into the RAM 226 
from the controller 110 or from a host computer or 
external storage device via the controller 110. 

The communication function of the reader 200 will 
now be described based upon the block diagram of Fig. 5. 

25 Among the functions incorporated within the MPU 

228, a CPU 240, a DMAC 241 and an SCU 242 are 



illustrated in the block diagram of Fig. 5. These 
functional blocks are connected to the RAM 226 via an 
address/data bus 234. A detailed description regarding 
the sending and receiving of data in the usual (i.e., 
5 without the intermediary of a DMAC) one-byte units is 
not given here as such a scheme is ordinary. What will 
be described in detail here is operation in which the 
DMAC and SCU are combined. 

First, in regard to a transmitting operation, the 
10 CPU 240 sets the length of data transmitted in a 

channel-0 transfer- length register of the DMAC 241 and 
sets the leading address of the transmit data string of 
RAM 226 in a channel-0 address register of the DMAC 241. 
When a transfer-start command is applied to the SCU 242, 
15 the latter makes TRUE a transfer request TXI (246) to 
the DMAC 241 successively in single-byte units. The 
transfer request TXI is connected to a channel-0 DMA 
request (DREQO ; 246) of the DMAC 241. When the DMA 
request becomes TRUE, the DMAC 241 controls the 
20 address/data bus 243 in accordance with information that 
has been set and effects a data transfer from the RAM 
226 to the SCU 242. The SCU 242 converts the received 
one byte of data to a bit sequence and outputs the bit 
sequence to a TXD terminal 248 in a predetermined 
2 5 format. When a prescribed number of transfers have been 
completed, the DMAC 241 makes DENDO (244) TRUE and 



notifies the CPU 240 of the end of transmission. The 
CPU 240 senses end of transmission by the signal on an 
interrupt terminal INTO (244) . 

Next, in regard to a receiving operation, the CPU 
5 240 sets the length of a fixed- length packet in a 

channel-1 transfer- length register of the DMAC 241 and 
sets the leading address of a receive buffer of RAM 226 
in a channel-1 address register of the DMAC 241. When a 
bit sequence is received from an RXD terminal 249, the 

10 SCU 242 converts this to byte data and then makes TRUE a 
transfer request RXI (247) to the DMAC 241. The RXI 
(247) is connected to a channel-1 DMA request (DREQ1; 
247) of the DMAC 241. When the DMA request becomes 
TRUE, the DMAC 241 controls the address/data bus 243 in 

15 accordance with information that has been set and 

effects a data transfer from the SCU 242 to the RAM 226. 
When reception of the prescribed number has been 
completed, the DMAC 241 makes DENDl (245) TRUE and 
notifies the CPU 240 of the end of transmission. The 

2 0 CPU 240 senses end of transmission. The CPU 240 senses 
end of reception by the signal on an interrupt terminal 
INT1 (245) . 

<Example of operation of system according to this 
embodiment > 

2 5 Described next will be a procedure for transferring 

a variable- length message by a fixed- length scheme 



between the image control unit and the image 
input/output unit. 

In this example, a procedure through which the CPU 
112 (Fig. 3) of the control unit (controller) 110 and 
5 the CPU 240 (Fig. 5) of the reader 200 select the fixed- 
length packet scheme at the time of initialization and a 
transfer procedure based upon the fixed-length packet 
scheme will be described with reference to the 
flowcharts shown in Figs. 6 and 7. It should be noted, 
10 however, that a technical concept similar to that of the 
example of Figs. 6 and 7 is applicable to determination 
of communication conditions between the printer and 
controller of this example and to determination of 
communication conditions in a system in which a 
15 plurality of devices have been connected via other 

communication means. In Figs. 6A and 6B, the dashed- 
line arrows between Fig. 6 A and Fig. 6B indicate 
communication between the reader and controller. 
(Operation of reader) 
20 A communication- scheme determination sequence in 

the reader 200 shown in Fig. 1 will be described first 
with reference to the flowchart shown in Fig. 6A. 

In Fig. 6A, the RAM and various peripheral circuits 
are initialized when power is applied (S601) . Next, the 
2 5 serial communication controller (SCU) 242 is initialized 
according to predetermined conditions (S602) . In this 
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embodiment, the conditions set are a baud rate of 9600 
bps, data of eight bits, stop bits of two bits and odd 
parity. Further, the SCU 242 is configured so as to 
operate in direct connection with the CPU 240 without 
5 the intermediary of the DMAC 241. 

Next, in order to inform the controller 110 of the 
fact that message reception has become possible, a CTS 
signal, which is a flow-control signal, is made TRUE 
(S603) and a message-reception standby state is attained 
10 (S604) . 

The reader receives a "communication negotiation 
start message" from the controller 110 and accepts 
information indicating "communication 

possible/ impossible according to fixed- length packet 
15 scheme" and an upper-limit value (PLCmax) of the length 
of the fixed-length packet, which are contained in the 
message {step S605) - In this example, the information 
"communication possible according to fixed-length packet 
scheme" and "upper-limit value of packet length is 
20 PLCmax bytes" is delivered to the reader 2 00 from the 
controller 110. The reader 200 compares this 
information with its own capabilities, namely whether 
fixed- length communication is possible/ impossible and 
the maximum allowable value (PLRmax) of packet length 
25 and decides the final communication conditions (S606) . 

In this example, it is decided to "perform communication 



according to fixed- length packet scheme" and the smaller 
of PLCmax and PLRmax is adopted to decide packet length 
PLen. For example, if PLCmax is 16 bytes and PLRmax is 
8 bytes, then 8 bytes is adopted as the packet length. 
5 Next, the reader transmits the above-mentioned 

communication conditions to the controller 110 together 
with a "communication negotiation completed" message 
(S607) . 

If transmission of the message is completed, then 
10 reception by DMA is set in the SCU 242 and DMAC 241 

(S608: set DMA transfer length to PLen bytes) . This is 
followed by waiting for a "resume communication" message 
from the controller 110 (S609) . When the "communication 
resumed" message is received from the controller 110, 
15 ordinary processing is started (S610) . 
(Operation of controller) 

Next, a communication- scheme determination sequence 
in the controller 110 shown in Fig. 1 will be described 
with reference to the flowchart shown in Fig. 6B. 

20 In Fig. 6B, the RAM and various peripheral circuits 

are initialized when power is applied (S621) . Next, the 
serial communication controller 127 is initialized 
according to predetermined conditions (S622) . In this 
embodiment, the conditions set are a baud rate of 9600 

25 bps, data of eight bits, stop bits of two bits and odd 
parity. 



Next, in order to inform the reader 200 of the fact 
that message reception has become possible, an RTS 
signal, which is a flow-control signal, is made TRUE 
(S623) and the controller waits for the reader to attain 
5 a state in which reception is possible (S624) . 

After it is recognized that the CTS signal has 
become TRUE, the controller transmits a "communication 
negotiation start message" (S62 5) . The communication 
scheme allowed by the controller is attached to this 
10 message as a parameter. In this example, the 

information "communication possible according to fixed- 
length packet scheme" and "upper- limit value of packet 
length is PLCmax bytes" is delivered. 

Next, the controller awaits an answer message from 
15 the reader (S626) . When the "communication negotiation 
completed" message is received, the communication 
controller 127 is set again based upon the communication 
scheme that was added on as the parameter (S627). 

Next, the controller waits 100 ms for the resetting 
2 0 of the communication conditions on the reader side and 

then transmits the "resume communication" message (S629) 
to start ordinary processing (S630) . 
(Reader transmission procedure) 
A data transmission sequence according to the 
2 5 fixed- length packet scheme in the reader 2 00 shown in 
Fig. 1 will now be described with reference to the 



flowchart of Fig. 7A. In this embodiment , the procedure 
will be described taking a case in which PLen = 8 bytes 
holds as an example, an 18 -byte message, for example, 
being transmitted upon being divided into 8-byte 
5 packets . 

First, an example of the data format of the packets 
will be described with reference to Fig. 8. 

In the leading byte of each packet, message IDs are 
added onto the seven lower order bits and flag 

10 information indicative of the final packet is added onto 
the most significant bit. Accordingly, a 7-byte message 
can be transferred by an 8-byte packet. The 18 -byte 
message is divided into three packets (7+7+4) . In the 
final packet, 3-byte dummy data is added on as padding. 

15 The CPU 240 generates this packet in the RAM 226 

(S7 01) , sets the leading address thereof and the 
transfer length (18 bytes) thereof in the channel-0 
register of the DMAC 241 (S7 02) and instructs the SCU 
242 to start transmission (S703) . 

2 0 Data transfer is carried out by the SCU 242 and 

DMAC 241 (S7 04) . When a prescribed number of data 
transfers have been completed, the DMAC 241 applies an 
interrupt to the CPU 240 (S7 05) and the CPU 240 executes 
post-processing (S706) . 

25 Transmission of the message is thenceforth repeated 

through the same procedure. 



(Reader reception procedure) 

A data reception, sequence according to the fixed- 
length packet scheme in the reader 200 will now be 
described with reference to the flowchart of Fig. 7B. 
5 At the time of reception, the CPU 240 sets the 

fixed packet length of eight bytes, which was decided in 
the initialization sequence, in the channel-1 register 
of the DMAC 241 as the DMA transfer length and sets the 
address of a receive buffer provided in the RAM 22 6 in 
10 the channel-1 register of the DMAC 241 as the DMA 
transfer address (S710) . 

When data is transferred from the controller 110, 
an 8-btye receive operation is performed by the DMAC 241 
and SCU 242 and the received data is transferred to the 
15 RAM 22 6 (S711) . When transfer of eight bytes is 

completed, the DMAC 241 applies an interrupt to the CPU 
240 (S712) and the CPU 240 executes post-processing 
(S713) . 

The CPU 240 checks " final -packet information" that 
2 0 has been added onto the packet (S714) . If the CPU 240 
recognizes that the packet is a final packet, it 
reproduced the original message (S715) . If the packet 
is not the final packet, the CPU 240 advances the 
pointer of the receive buffer (S716) and control returns 
25 to the processing of step S710 . 

Message reception is thenceforth repeated through 
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the same procedure. 

In the example set forth above, communication 
negotiation processing (determination of fixed packet 
length) is executed by the reader, though this 
5 processing may be executed by the controller- However, 
in a case where a large number of structural elements 
have been connected to the system, executing the 
communication negotiation processing by the controller 
will take too much time. In such case it is preferred 

10 that the processing be executed on the side of each of 
the connected elements. Further, it is possible for 
data send/receive processing on the side of the 
controller 110 also to be carried out through exactly 
the same procedure. 

15 Thus, in accordance with the embodiment as 

described above, by adopting a scheme in which a 
variable- length message is transferred upon being 
divided into fixed-length packets, it is possible to 
combine and control a DMA controller and a communication 

2 0 controller, thereby achieving high-speed data 

communication, even in a system not possessing a high- 
performance communication controller. 

Further, depending upon the selection as to whether 
or not to implement a fixed- length packet scheme and the 

25 method of deciding the upper-limit value of packet 

length by negotiation between devices at the time of 
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initialization, it is possible to realize a data 
communication scheme having greater versatility. 

The present invention can be applied to a system 
constituted by a plurality of devices (e.g., a host 
5 computer, interface, reader, printer, etc.) or to an 

apparatus comprising a single device (e.g., a copier or 
facsimile machine, etc.). 

Furthermore, it goes without saying that the object 
of the invention is attained also by supplying a storage 

10 medium (or recording medium) storing the program codes 
of the software for performing the functions of the 
foregoing embodiment to a system or an apparatus, 
reading the program codes, which have been stored on the 
storage medium, with a computer (or CPU or MPU) of the 

15 system or apparatus from the storage medium, and then 

executing the program codes. In this case, the program 
codes read from the storage medium implement the 
functions of the embodiment, and the storage medium 
storing the program codes constitutes the invention. 

20 Furthermore, besides the case where the aforesaid 

functions according to the embodiment are implemented by 
executing the program codes read by a computer, it goes 
without saying that the present invention covers a case 
where an operating system or the like running on the 

2 5 computer performs a part of or the entire process in 
accordance with the designation of program codes and 



implements the functions of the embodiment by this 
processing . 

It goes without saying that the present invention 
further covers a case where, after the program codes 
5 read from the storage medium are written in a function 
expansion board inserted into the computer or in a 
memory provided in a function expansion unit connected 
to the computer, a CPU or the like contained in the 
function expansion board or function expansion unit 

10 performs a part of or the entire process in accordance 

with the designation of program codes and implements the 
functions of the embodiment by this processing. 

In a case where the present invention is applied to 
the above-described storage medium, program code 

15 corresponding to the flowcharts (shown in Figs. 6A and 
6B and/or Figs. 7A and 7B) described earlier would be 
stored on this storage medium. 

Thus, in accordance with this embodiment as 
described above, it is possible to provide a method and 

20 system for data communication between devices, wherein 
by adopting a scheme in which a variable- length message 
is transferred upon being divided into fixed-length 
packets, it is possible to combine and control a DMA 
controller and a communication controller, thereby 

25 achieving high-speed data communication, even in a low- 
cost single-chip microcomputer. 



As many apparently widely different embodiments of 
the present invention can be made without departing from 
the spirit and scope thereof, it is to be understood 
that the invention is not limited to the specific 
embodiments thereof except as defined in the appended 
claims . 
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WHAT IS CLAIMED IS: 

1. An image processing system comprising a combination 
of an image control unit and one or a plurality of image 

5 input/output units, wherein said image input /output unit 
and said image control unit are connected by 
communication means, said image control unit has first 
communication control means connected to said 
communication means, said image input/output unit has 

10 second communication control means connected to said 
communication means, and said system further includes 
control means for performing control so as to set 
predetermined communication conditions in said first and 
second communication control means at initialization, 

15 decide fixed packet length based upon mutually 

communicable packet lengths of packets exchanged via 
said communication means, set the decided fixed packet 
length in said first and second communication control 
means anew, and continue subsequent communication by DMA 

2 0 transfer in which a data string is divided into the set 
fixed packet lengths. 

2. The system according to claim 1, wherein in a case 
where the data string is a variable- length message, said 
control means performs control in such a manner that a 

2 5 transmitting side adds information indicative of the end 
of a message onto a final packet when the variable- 
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length message is transmitted upon being divided into 
fixed- length packets, and a receiving side reproduces 
the original variable- length message after recognizing 
added-on final-packet information. 
5 3. The system according to claim 1, wherein said 

control means includes first control means in said image 
control unit for controlling said first communication 
control means, and second control means in said image 
input/output unit for controlling said second 
10 communication control means. 

4. The system according to claim 3, wherein the 
decision of the fixed packet length is made by said 
first control means. 

5. The system according to claim 3, wherein the 

15 decision of the fixed packet length is made by said 
second control means . 

6. The system according to claim 1, wherein the fixed 
packet length decided upon is whichever of the packet 
lengths of respective ones of said first and second 

20 communication control means is smaller than an upper- 
limit value. 

7. The system according to claim 1, wherein an image 
reading unit is connected as the image input/output unit 
and the system operates as an image reading system. 

25 8. The system according to claim 1, wherein an image 

forming unit is connected as the image input/output unit 
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and the system operates as an image forming system. 

9. The system according to claim 1, wherein an image 
reading unit and an image forming unit are connected as 
the image input/output units and the system functions as 

5 an image input /output system. 

10. The system according to claim 1, wherein start-stop 
synchronization serial communication means is used as 
said communication means, a serial communication 
controller and a DMA controller are combined as said 

10 communication control means, the DMA controller 

transfers data by the fixed-length packets in accordance 
with a data transfer request from said serial 
communication controller and interrupts said image 
control unit when transfer of the fixed-length packet is 

15 completed. 

11. A system constructed by combining a plurality of 
devices and connecting them by communication means, 
wherein a first device has first communication control 
means connected to said communication means, a second 

2 0 device has second communication control means connected 
to said communication means, and the system further 
includes control means for performing control so as to 
set predetermined communication conditions in said first 
and second communication control means at 

25 initialization, decide fixed packet length based upon 
mutually communicable packet lengths of packets 



exchanged via said communication means, set the decided 
fixed packet length in said first and second 
communication control means anew, and continue 
subsequent communication. 
5 12. The system according to claim 11, wherein in a case 
where a data string is a variable- length message, said 
control means performs control in such a manner that a 
transmitting side adds information indicative of the end 
of a message onto a final packet when the variable- 
10 length message is transmitted upon being divided into 
fixed-length packets, and a receiving side reproduces 
the original variable- length message after recognizing 
added-on final-packet information. 

13 . A data communication method in an image processing 
15 system comprising a combination of an image control unit 
and one or a plurality of image input/output units, said 
image input/output unit and said image control unit 
being connected by communication means, wherein in a 
case where said image control unit has first 
20 communication control means connected to said 

communication means and said image input /output unit has 
second communication control means connected to said 
communication means, said method comprises: 

an initial communication conditions setting step of 
2 5 setting predetermined communication conditions in the 
first and second communication control means at 
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initialization; 

a fixed packet length deciding step of deciding 
fixed packet length based upon mutually communicable 
packet lengths of packets exchanged via the 
5 communication means; and 

a fixed packet length setting step of setting the 
decided fixed packet length in the first and second 
communication control means anew and continuing 
subsequent communication by DMA transfer in which a data 
10 string is divided into the set fixed packet lengths. 

14 . The method according to claim 13 , wherein in the 
fixed-packet length deciding step, the fixed packet 
length decided upon is whichever of the packet lengths 
of respective ones of the first and second communication 

15 control means is smaller than an upper-limit value. 

15. The method according to claim 13, wherein after the 
fixed packet length has been set anew, communication is 
resumed upon elapse of a predetermined period of time. 

16. The method according to claim 13, wherein start- 
20 stop synchronization serial communication means is used 

as said communication means, a serial communication 
controller and a DMA controller are combined as said 
communication control means, the DMA controller 
transfers data by the fixed- length packets in accordance 
25 with a data transfer request from said serial 

communication controller and interrupts said image 



control unit when transfer of the fixed-length packet is 
completed. 

17 . A data communication method in a system constructed 
by combining a plurality of devices and connecting them 

5 by communication means, wherein in a case a first device 
has first communication control means connected to said 
communication means and a second device has second 
communication control means connected to said 
communication means, said method comprises the steps of: 
10 setting predetermined communication conditions in 

the first and second communication control means at 
initialization; 

deciding fixed packet length based upon mutually 
communicable packet lengths of packets exchanged via the 
15 communication means; and 

setting the decided fixed packet length in the 
first and second communication control means anew and 
continuing subsequent communication. 

18. The method according to claim 17, wherein in a case 
20 where a data string is a variable- length message, a 

transmitting side adds information indicative of the end 
of a message onto a final packet when the variable- 
length message is transmitted upon being divided into 
fixed- length packets, and a receiving side reproduces 
25 the original variable- length message after recognizing 
added-on final-packet information. 
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19 . A storage medium storing a computer-readable 
communication control program of an image processing 
system comprising a combination of an image control unit 
and one or a plurality of image input /output units, the 
5 image input /output unit and the image control unit being 
connected by communication means, wherein in a case 
where said image control unit has first communication 
control means connected to said communication means and 
said image input/output unit has second communication 
10 control means connected to said communication means, 
said communication control program includes: 

an initial communication conditions setting step of 
setting predetermined communication conditions in the 
first and second communication control means at 
15 initialization; 

a fixed packet length deciding step of deciding 
fixed packet length based upon mutually communicable 
packet lengths of packets exchanged via the 
communication means; and 
2 0 a fixed packet length setting step of setting the 

decided fixed packet length in the first and second 
communication control means anew and continuing 
subsequent communication by DMA transfer in which a data 
string is divided into the set fixed packet lengths. 
25 20. The storage medium according to claim 19, wherein 
the communication control program includes a program in 
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said image control unit executed by a first control unit 
for controlling said first communication control means, 
and a program in said image input /output unit executed 
by a second control unit for controlling said second 
communication control means. 
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ABSTRACT OF THE DISCLOSURE 



An image processing system comprising a combination 
of an image control unit and one or a plurality of image 
input/output units, wherein the image control unit and 
image input/output unit are connected by communication 
means. In a case where the image control unit has a 
first communication controller and the image 
input /output unit has a second communication controller, 
predetermined communication conditions are set in the 
first and second communication controllers at 
initialization, a fixed packet length is decided based 
upon mutually communicable packet lengths of packets 
exchanged via the communication means, the decided fixed 
packet length is set in the first and second 
communication controllers anew, and subsequent 
communication is continued by DMA transfer in which a 
data string is divided into the set fixed packet 
lengths. As a result, high-speed data communication is 
achieved between units even in a low-cost single-chip 
microcontroller . 
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